

WHAT IS CLAIMED IS:

1. A turbo-code decoder for communication system, the decoder comprising:
  - a serial-to-parallel output unit, used to receive a serial input signal and output a parallel signal after converting the serial input signal; and
  - 5 a plurality of parallel decoding units, wherein the parallel decoding units are serially connected to form a plurality of levels, the first level parallel decoding unit receives the parallel signal that is output from the serial-to-parallel output unit, the output from the first level parallel decoding unit is sent to the second level parallel decoding unit, with certain sequence, the parallel signal passes through the parallel decoding units for 10 decoding process.
2. The turbo-code decoder of claim 1, wherein each of the parallel decoding unit receives an extrinsic parameter when processing the decoding process, to be the signal that is after the decoding process from the parallel decoding unit, and sends the extrinsic parameter to the next level of the parallel decoding unit.
- 15 3. The turbo-code decoder of claim 2, wherein the extrinsic parameter is obtained from a deinterleaving operation, the extrinsic parameter of the first level parallel decoding unit is  $L_{a0,k}=(0,0\dots,0)$ , where  $k=1, 2, \dots, N$ ,  $N$  is the block length of the turbo-code.
4. The turbo-code decoder of claim 1, wherein the serial input signal are  $r_{is,k}$ ,  $r_{ip,k}$ , 20 and  $r_{2p,k}$  messages of the turbo-code, whereas  $k=1, 2, \dots, N$ ,  $N$  is the block length of the turbo-code.
5. The turbo-code decoder of claim 4, wherein the serial-to-parallel output unit receives the  $r_{is,k}$ ,  $r_{ip,k}$ , and  $r_{2p,k}$ , wherein the subscript  $K=0, 1, \dots, N+M-1$  represents the whole block and an end message, wherein  $M$  stands for a total number of latch units of

the turbo-code decoder, the serial-to-parallel output unit converts the received  $r_{ls,k}$ ,  $r_{lp,k}$ , and  $r_{2p,k}$  messages and outputs results to the first level parallel decoding unit in parallel, the first level parallel decoding unit also receives an extrinsic parameter  $L_{a,k}$  at the same time, the parameter  $L_{a,k}$  is obtained via a deinterleaving operation on the previous level extrinsic 5 parameter  $\Lambda(d_k)$ , the initial value of the first level decoding unit extrinsic parameter is set as  $L_{a0,k} = (0, 0 \dots, 0)$ , a first level extrinsic parameter  $L_{a1,k}$  is generated via the first level parallel decoding unit, and the message  $r_{ls,k}$ ,  $r_{lp,k}$  and  $r_{2p,k}$  pass through sequentially to be the input of the next level.

6. The turbo-code decoder of claim 5, wherein the parallel decoding unit  
10 comprises:

a first decoder, used to receive the  $r_{ls,k}$ ,  $r_{lp,k}$  messages and the extrinsic parameter  $L_{a,k}$ ;  
a second decoder, used to receive the  $r_{2p,k}$  message and the extrinsic parameter  $L_{a,k}$ ;  
an interleaving unit, located between the first decoder and the second decoder,  
15 used to receive the output of the first decoder; and  
a deinterleaving unit, used to connected to the second decoder, alternately outputs  
the output of the first decoder and the second decoder.

7. The turbo-code decoder of claim 6, wherein the first decoder of the parallel  
decoding units constitutes a systolic array very large scaled integrated (VLSI) circuits  
20 structure.

8. The turbo-code decoder of claim 7, wherein the systolic array VLSI circuits is  
composed of  $N+M$  units of the module C, A, B, D, and E, wherein,  
the module C receives  $L_{a1,k}$ ,  $r_{ls,k}$  and  $r_{lp,k}$ , and outputs  $\gamma_k^{(1)}(m', m)$  and  $\gamma_k^{(0)}(m', m)$ ,  
the module A calculates a forward recursive probability parameter  $\alpha_k$ ,

the module B calculates a backward recursive probability parameter  $\beta_k$ ,

the module D adopts (N+M) units of parallel calculation to obtain the  $\Lambda(d_k)$  after

the calculation of the  $\alpha_k$ ,  $\beta_k$ , and  $\gamma_k^{(i)}$  are finished, and

the module E outputs the value of the calculation from the module D, where K=1,

5 2,..., N+M.

9. The turbo-code decoder of claim 8, wherein the value of the  $\Lambda(d_k)$  is calculated according to a MAP algorithm and following equation:

$$\Lambda(d_k) = \log \frac{\sum_{m'} \sum_{m} \gamma_k^{(1)}(m', m) \cdot \alpha_{k-1}(m') \cdot \beta_k(m)}{\sum_m \sum_{m'} \gamma_k^{(0)}(m', m) \cdot \alpha_{k-1}(m') \cdot \beta_k(m)},$$

wherein  $\alpha_k$  is the forward recursive probability parameter,  $\beta_k$  is the backward

10 recursive probability parameter,  $\gamma_k^{(i)}$  is a branch probability parameter.

10. The turbo-code decoder of claim 9, wherein the forward recursive probability parameter  $\alpha_k$  is obtained from the calculation of the previous parameter  $\alpha_{k-1}(m)$  and the branch probability parameter  $\gamma_k^{(i)}$ , the equation is as follows:

$$\alpha_k(m) = \frac{\sum_{m'} \sum_{i=0}^1 \gamma_k^{(i)}(m', m) \cdot \alpha_{k-1}(m')}{\sum_m \sum_{m'} \sum_{i=0}^1 \gamma_k^{(i)}(m', m) \cdot \alpha_{k-1}(m')}$$

15 11. The turbo-code decoder of claim 9, wherein the backward recursive probability parameter  $\beta_k$  is obtained from the calculation of the next parameter  $\beta_{k+1}$  and the branch probability parameter  $\gamma_{k+1}^{(i)}$ , the equation is as follows:

$$\beta_k(m) = \frac{\sum_{m'} \sum_{i=0}^1 \gamma_{k+1}^{(i)}(m', m) \cdot \beta_{k+1}(m')}{\sum_m \sum_{m'} \sum_{i=0}^1 \gamma_{k+1}^{(i)}(m', m) \cdot \beta_{k+1}(m')}$$

12. The turbo-code decoder of claim 9, wherein the branch probability parameter

$\gamma_k^{(i)}$  is obtained from following equation according to the MAP algorithm:

$$\begin{aligned} \gamma_k^{(i)}(m', m) &= p(r_{ls,k} | d_k = i, s_k = m, s_{k-1} = m') \cdot p(r_{ls,k} | d_k = i, s_k = m, s_{k-1} = m') \cdot \\ &q(d_k = i | s_k = m, s_{k-1} = m') \cdot \Pr\{s_k = m | s_{k-1} = m'\} \end{aligned}$$

5

wherein whether the probability parameter  $q(d_k = i | s_k = m, s_{k-1} = m')$  is 0 or 1

depends on the input bit  $d_k = i$  is 0 or 1 combines the probability of the state  $m'$  to the state  $m$ .

13. The turbo-code decoder of claim 11, wherein, assuming in a AWGN channel,

10 the probability is calculated as follows:

$$p(r_{ls,k} | d_k = i, s_k = m, s_{k-1} = m') = \frac{1}{\sqrt{2\pi}\sigma_{rls}} \exp\left[-\frac{(r_{ls,k} - \mu_{rls})^2}{2\sigma_{rls}^2}\right]$$

$$p(r_{lp,k} | d_k = i, s_k = m, s_{k-1} = m') = \frac{1}{\sqrt{2\pi}\sigma_{rlp}} \exp\left[-\frac{(r_{lp,k} - \mu_{rlp}(m', m))^2}{2\sigma_{rlp}^2}\right] ,$$

wherein  $\mu_{rls}$  and  $\mu_{rlp}(m', m)$  is the expectation value of  $r_{ls}$  and  $r_{lp}$  respectively,

thereinto,  $\mu_{rls}$  depends on the input bit, and  $\mu_{rlp}(m', m)$  depends on the input bit and also  
15 impacted by the previous state and current state,  $\mu_{rlp}$  and  $\sigma_{rlp}^2$  is the variant of the  $r_{ls}$  and  
 $r_{lp}$  respectively.

14. The turbo-code decoder of claim 12, wherein, assuming that the variant of  $r_{ls}$  and  
and  $r_{lp}$  are the same, therefore, the above two equations can be multiplied and  
consolidated as follows:

$$p(r_{ls,k} | d_k = i, s_k = m, s_{k-1} = m') \cdot p(r_{lp,k} | d_k = i, s_k = m, s_{k-1} = m')$$

$$= \frac{1}{2\pi\sigma^2} \exp \left[ \frac{-1}{2} \cdot \frac{(r_{ls,k} - \mu_{rls})^2 + (r_{lp,k} - \mu_{rlp}(m', m))^2}{\sigma^2} \right]$$

15. The turbo-code decoder of claim 11, wherein assuming for a discrete memory-less gauss channel, the branch probability parameter  $\gamma_k^{(1)}$  or  $\gamma_k^{(0)}$  for input bit being 1 or 0 can be calculated from the equation as follows:

5

$$\gamma_k^{(1)}(m', m) = \frac{1}{2\pi\sigma^2} \exp \left[ \frac{-1}{2} \cdot \frac{(r_{ls,k} - 1)^2 + (r_{lp,k} - \mu_{rlp}(m', m))^2}{\sigma^2} \right] \cdot \frac{e^{L(d_k)}}{1 + e^{L(d_k)}}$$

$$\gamma_k^{(0)}(m', m) = \frac{1}{2\pi\sigma^2} \exp \left[ \frac{-1}{2} \cdot \frac{(r_{ls,k} + 1)^2 + (r_{lp,k} - \mu_{rlp}(m', m))^2}{\sigma^2} \right] \cdot \frac{1}{1 + e^{L(d_k)}}$$

16. The turbo-code decoder of claim 5, wherein the N=4 and the register size M=3, the simplified modules, a data stream, and a latch structure are shown as the content of FIG. 6.

10 17. The turbo-code decoder of claim 5, wherein the a priori probability of the input bit  $d_k$  calculated by the previous level parallel decoding unit can be used by the next level decoder.

18. The turbo-code decoder of claim 5, wherein  $L(d_k)$  is the log likelihood ratio (LLR) extrinsic parameter calculated from the message bit  $d_k$  by the previous level decoder.